Zum Hauptinhalt springen

Delete User Endpoint

Overview

This endpoint permanently deletes a user account and clears their session.

Request Details

HTTP Method

DELETE

Route

/api/users/[user_id]

Route Parameters

ParameterTypeRequiredDescription
user_idintegerYesUnique identifier of the user

Headers

HeaderValueRequiredDescription
Cookieneptun-sessionYesSession authentication cookie

Query Parameters

No query parameters required.

Request Body

No request body required.

Response Format

Response Status Codes

Status CodeDescription
200User successfully deleted
400Invalid user ID format
401Unauthorized (invalid or missing session)
404User not found
500Server error during deletion

Success Response (200 OK)

Returns a boolean indicating whether the deletion was successful.

true

Error Response (400 Bad Request)

{
"statusCode": 400,
"statusMessage": "Bad Request",
"data": {
"message": "Invalid user ID format"
}
}

Error Response (404 Not Found)

{
"statusCode": 404,
"statusMessage": "Not Found",
"data": {
"message": "User not found"
}
}

TypeScript Interface

interface DeleteUserResponse {
success: boolean
}

interface DeleteUserError {
statusCode: number
statusMessage: string
data: {
message: string
}
}

Python Model

from pydantic import BaseModel

class DeleteUserResponse(BaseModel):
success: bool

class ErrorData(BaseModel):
message: str

class DeleteUserError(BaseModel):
statusCode: int
statusMessage: str
data: ErrorData

Code Examples

Python Example

from pydantic import BaseModel
import httpx

class DeleteUserResponse(BaseModel):
success: bool

async def delete_user(user_id: int, session_cookie: str) -> bool:
async with httpx.AsyncClient() as client:
response = await client.delete(
f"https://neptun-webui.vercel.app/api/users/{user_id}",
cookies={"neptun-session": session_cookie}
)
response.raise_for_status()
return response.json()

cURL Example

curl -X DELETE \
-H "Cookie: neptun-session=your-session-cookie" \
"https://neptun-webui.vercel.app/api/users/your-user-id"

TypeScript/JavaScript Example

async function deleteUser(userId: number): Promise<boolean> {
const response = await fetch(
`https://neptun-webui.vercel.app/api/users/${userId}`,
{
method: 'DELETE',
credentials: 'include', // Important for cookie handling
}
)

if (!response.ok) {
throw new Error(`HTTP error! status: ${response.status}`)
}

return await response.json()
}

Notes

  • The session cookie is required for authentication
  • Upon successful deletion, the user's session is automatically cleared
  • This action is permanent and cannot be undone
  • All associated user data will be deleted from the system